## PATENT ABSTRACTS OF JAPAN

(11)Publication number:

06-250798

(43) Date of publication of application: 09.09.1994

(51)Int.CI.

G06F 3/08 G11C 16/06

(21)Application number: 05-035228

(71)Applicant: INTERNATL BUSINESS MACH

CORP <IBM>

(22)Date of filing:

24.02.1993

(72)Inventor: NIIJIMA HIDETO

**ASANO HIDEO** 

SAKAGAMI YOSHIISA TOYOOK A TAKASHI

## (54) BATCH DELETE TYPE NONVOLATILE MEMORY AND SEMICONDUCTOR DISK DEVICE USING THE SAME

### (57)Abstract:

PURPOSE: To discriminate an invalid sector from a valid sector without using a method for overwriting by ensuring a cluster information sector in each cluster, applying a sequence number to the cluster so as not to be doubled, and writing the sequence number assigned to the cluster in the cluster information sector of each cluster.

CONSTITUTION: A batch delete type nonvolatile memory 20 can be deleted by each cluster unit, a cluster information sector is ensured in each of the N pieces of clusters, a sequence number is preliminarily applied to the N pieces of clusters so as not to be overlapped, and the sequence number of the cluster is written in the cluster information sector of each cluster. At the time of deleting a certain cluster, a controller 30 maintains the sequence number of the cluster at first, and at the time of initializing the deleted cluster, the controller 30 writes a value larger than the present maximum sequence number in the



cluster information sector as the sequence number of the cluster. The controller 30 writes user data according to the sequence number of the physical address of the sector.

#### LEGAL STATUS

[Date of request for examination]

28.11.1996

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

2856621

[Date of registration]

27.11.1998

|    | 1 |     | • 5 |  |
|----|---|-----|-----|--|
|    |   | a•2 |     |  |
|    |   |     |     |  |
|    |   |     |     |  |
|    |   |     |     |  |
|    |   |     |     |  |
|    |   |     |     |  |
|    |   |     |     |  |
|    |   |     | ž.  |  |
|    |   |     |     |  |
|    |   |     |     |  |
|    |   | 7.  |     |  |
| ** |   |     |     |  |
|    |   |     |     |  |

[Number of appeal against examiner's decision of rejection]
[Date of requesting appeal against examiner's decision of rejection]
[Date of extinction of right]

Copyright (C); 1998,2000 Japan Patent Office

|     |  |   |   | <b>.</b> |
|-----|--|---|---|----------|
|     |  | • |   | **       |
|     |  |   |   |          |
|     |  |   | - |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   | ~        |
|     |  |   |   |          |
|     |  | 4 |   | -        |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   | ÷ | •        |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
| A-E |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |
|     |  |   |   |          |

#### (19)日本国特許庁(JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号

## 特開平6-250798

(43)公開日 平成6年(1994)9月9日

(51)Int.Cl.5

識別記号 庁内整理番号

技術表示箇所

G06F 3/08 G 1 1 C 16/06 H 7165-5B

6866-5L

G 1 1 C 17/00

FΙ

309 C

審査請求 未請求 請求項の数15 OL (全 16 頁)

(21)出願番号

特願平5-35228

(22)出願日

平成5年(1993)2月24日

(71)出願人 390009531

インターナショナル・ビジネス・マシーン

ズ・コーポレイション

INTERNATIONAL BUSIN ESS MASCHINES CORPO

RATION

アメリカ合衆国10504、ニューヨーク州

アーモンク (番地なし)

(72)発明者 新島 秀人

東京都千代田区三番町5-19 日本アイ・

ピー・エム株式会社 東京基礎研究所内

(74)代理人 弁理士 頓宮 孝一 (外4名)

最終頁に続く

#### (54)【発明の名称】 一括消去型不揮発性メモリおよびそれを用いる半導体ディスク装置

#### (57) 【要約】

【目的】重ね書きの手法を用いなくても無効セクタと有 効セクタとを見分けることが可能な一括消去型不揮発性 メモリ及びそれを用いた半導体ディスク装置を提供する こと。

【構成】一括消去型不揮発性メモリは、クラスタ単位で 消去することが可能であり、N個のクラスタの各々にク ラスタ情報セクタが確保され、予めN個のクラスタに対 して重複がないように順序番号が与えられ、各クラスタ のクラスタ情報セクタに当該クラスタに割り当てられた 順序番号が書き込まれている。コントローラは、所与の クラスタを消去するとき、先に当該クラスタの順序番号 を保管する。そして、所与の消去済みクラスタを初期設 定するときには、現在の最大順序番号よりも大きな値を 当該クラスタの順序番号としてそのクラスタ情報セクタ に書き込む。このようにして初期設定されたクラスタの クラスタ情報セクタ以外のセクタに対して、コントロー ラは、それらセクタの物理アドレスの順番に従ってユー ザ・データを書き込む。



#### 【特許請求の範囲】

【請求項1】各々がM個のセクタからなるN個のクラス タを有し(M、Nは各々2以上の整数)、クラスタ単位 で消去することが可能であり、

上記N個のクラスタの各々にクラスタ情報セクタが確保 05 等しく設定されており、 され、

上記N個のクラスタに対して重複がないように順序番号 が与えられ、各クラスタのクラスタ情報セクタに当該ク ラスタに割り当てられた順序番号が書き込まれているこ とを特徴とする一括消去型不揮発性メモリ。

【請求項2】上記N個のクラスタ情報セクタの各々には さらに当該クラスタの消去回数が書き込まれ、上記N個 のクラスタに与えられた順序番号の最大値はそれらクラ スタの消去回数の総和に等しいことを特徴とする請求項 1 記載の一括消去型不揮発性メモリ。

【請求項3】コントローラと、

各々がM個のセクタからなるN個のクラスタを有し (M、Nは各々2以上の整数)、クラスタ単位で消去す ることが可能な一括消去型不揮発性メモリとを備え、 上記N個のクラスタの各々にクラスタ情報セクタが確保 20 され、

上記コントローラの動作に先立って、上記N個のクラス タに対して重複がないように順序番号が与えられ、各ク ラスタのクラスタ情報セクタに当該クラスタに割り当て られた順序番号が書き込まれており、

上記コントローラは、

所与のクラスタを消去するときは、先に当該所与のクラ スタの順序番号を保管し、

所与の消去済みクラスタを初期設定するときは、現在の 最大順序番号よりも大きな値を当該所与のクラスタの順 30 上記コントローラは、 序番号としてそのクラスタ情報セクタに書き込むことを 特徴とする半導体ディスク装置。

【請求項4】上記コントローラは、所与のクラスタに対 してユーザ・データの書込みを開始した後、当該クラス タに対するユーザ・データの書込みが終了するまで、他 35 のクラスタへのユーザ・データの書込みを行わないこと を特徴とする請求項3記載の半導体ディスク装置。

【請求項5】上記コントローラは、上記所与のクラスタ のクラスタ情報セクタ以外のセクタに対してそのアドレ は4記載の半導体ディスク装置。

【請求項6】コントローラと、

各々がM個のセクタからなるN個のクラスタを有し

(M、Nは各々2以上の整数)、クラスタ単位で消去す ることが可能な一括消去型不揮発性メモリとを備え、 上記N個のクラスタの各々にクラスタ情報セクタが確保 され、

上記コントローラの動作に先立って、上記N個のクラス タに対して重複がないように順序番号が与えられ、各ク ラスタのクラスタ情報セクタに当該クラスタに割り当て られた順序番号が書き込まれており、且つ、上記N個の クラスタ情報セクタの各々にはさらに当該クラスタの消 去回数が書き込まれ、上記N個のクラスタに与えられた 順序番号の最大値はそれらクラスタの消去回数の総和に

上記コントローラは、

所与のクラスタを消去するときは、先に当該所与のクラ スタの順序番号と消去回数を保管し、

所与の消去済みクラスタを初期設定するときは、現在の 10 最大順序番号に1を加算し、且つ消去前に保管された消 去回数に1を加算し、加算結果をそれぞれ当該所与のク ラスタの順序番号及び消去回数としてそのクラスタ情報 セクタに書き込むことを特徴とする半導体ディスク装 骨。

- 15 【請求項7】プロセッサからの論理アドレスによってア クセスされる半導体ディスク装置であって、

上記プロセッサに接続されたコントローラと、

各々がM個のセクタからなるN個のクラスタを有し

(M、Nは各々2以上の整数)、クラスタ単位で消去す ることが可能な一括消去型不揮発性メモリと、

上記コントローラに接続されたランダム・アクセス・メ モリとを備え、

上記一括消去型不揮発性メモリは、

上記N個のクラスタの各々にクラスタ情報セクタが確保 25 され、

上記コントローラの動作に先立って、上記N個のクラス タに対して重複がないように順序番号が与えられ、各ク ラスタのクラスタ情報セクタに当該クラスタに割り当で られた順序番号が書き込まれており、

上記プロセッサのコマンドに含まれる論理アドレスを特 定のセクタを指示する物理アドレスに変換するために上 記ランダム・アクセス・メモリ上にアドレス変換表の領 域を確保し、

上記プロセッサが所与の論理アドレスを指定して書込み を要求したときに、上記一括消去型不揮発性メモリの空 白セクタを一つ選択し、上記アドレス変換表の当該所与 の論理アドレスによって指示される項目に当該選択され たセクタの物理アドレスを書き込み、且つ当該選択され スの順番に従ってユーザ・データを書き込む請求項3又 40 たセクタに当該所与の論理アドレスを逆参照ポインタと して書き込み、

> 所与のクラスタを消去するときは、先に当該クラスタの 順序番号を保管し、

所与の消去済みクラスタを初期設定するときは、現在の 45 最大順序番号よりも大きな値を当該クラスタの順序番号 としてそのクラスタ情報セクタに書き込むことを特徴と する半導体ディスク装置。

【請求項8】上記コントローラは、所与のクラスタに対 して

む

な

を

開始した

後、

当該

所与の

クラスタ

に対する 50 魯込みが終了するまでの期間、上記プロセッサの書き込

み要求に応答して当該所与のクラスタから物理アドレス の順に空白セクタを選択することを特徴とする請求項7 記載の半導体ディスク装置。

【請求項9】上記コントローラは、上記アドレス変換表 を再構成するときに、上記不揮発性メモリのM×N個の セクタを読み出し、読み出されたセクタの逆参照ポイン タによって指示される上記アドレス変換表の項目に当該 セクタの物理アドレスを書き込み、

同じ逆参照ポインタを持つセクタが複数あるときには、 それらセクタの属するクラスタの順序番号とクラスタ内 10 上記コントローラは、 での位置に従って、最も新しく書き込まれたセクタの物 理アドレスを上記アドレス変換表に書き込むことを特徴 とする請求項7又は8記載の半導体ディスク装置。

【請求項10】上記コントローラは、上記アドレス変換 表を再構成するときに、(a)上記M個のクラスタのク ラスタ情報セクタを読み出し、(b) 順序番号が最小の クラスタを選択し、(c)選択されたクラスタのセクタ を順次読み出し、読み出されたセクタの逆参照ポインタ によって指示される上記アドレス変換表の項目に当該セ に従って次のクラスタを選択し上記(c)の動作を行う ことを反復することを特徴とする請求項7又は8記載の 半導体ディスク装置。

【請求項11】上記コントローラは、上記アドレス変換 いて、

当該クラスタのクラスタ情報セクタを読み出し、 当該クラスタのアドレスとその順序番号の対応関係を上 記ランダム・アクセス・メモリに表形式で記憶し(以 下、この表を順序番号表と呼ぶ)、

当該クラスタのクラスタ情報セクタ以外のセクタ(以 下、データ・セクタと呼ぶ)を順次読み出し、

読み出されたデータ・セクタの逆参照ポインタによって 指示されるアドレス変換表の項目を読み出し、

当該項目が空白であるならば、そこに当該読み出された 35 され、 データ・セクタの物理アドレスを書き込み、

当該項目が空白でないならば、そこに書き込まれた物理 アドレスに位置するセクタの属するクラスタの順序番号 を上記順序番号表を参照して求め、

上記求まった順序番号を現在読み出し中のクラスタの順 序番号と比較し、

上記求まった順序番号の方が小であるなら、上記読み出 されたデータ・セクタの物理アドレスを上記項目に書き 込むことを特徴とする請求項7又は8記載の半導体ディ スク装置。

【請求項12】プロセッサと、

上記プロセッサに接続されたコントローラと、 各々がM個のセクタからなるN個のクラスタを有し (M、Nは各々2以上の整数)、クラスタ単位で消去す ることが可能な一括消去型不揮発性メモリと、

上記コントローラに接続されたランダム・アクセス・メ モリとを備え、

上記一括消去型不揮発性メモリは、

上記N個のクラスタの各々にクラスタ情報セクタが確保 05 され、

上記コントローラの動作に先立って、上記N個のクラス タに対して重複がないように順序番号が与えられ、各ク ラスタのクラスタ情報セクタに当該クラスタに割り当て られた順序番号が書き込まれており、

上記プロセッサのコマンドに含まれる論理アドレスを特 定のセクタを指示する物理アドレスに変換するために上 記ランダム・アクセス・メモリ上にアドレス変換表の領 域を作成し、

15 上記プロセッサが所与の論理アドレスを指定して書込み を要求したときに、上記一括消去型不揮発性メモリの空 白セクタを一つ選択し、上記アドレス変換表の当該所与 の論理アドレスによって指示される項目に当該選択され たセクタの物理アドレスを書き込み、且つ当該選択され、 クタの物理アドレスを書き込み、(d)順序番号の昇順 20 たセクタに当該所与の論理アドレスを逆参照ポインタと して書き込み、

> 所与のクラスタを消去するときは、先に当該クラスタの 順序番号を保管し、

所与の消去済みクラスタを初期設定するときは、現在の 表を再構成するときに、上記M個のクラスタの各々につ 25 最大順序番号よりも大きな値を当該クラスタの順序番号 としてそのクラスタ情報セクタに書き込むことを特徴と するデータ処理システム。

【請求項13】プロセッサと、

上記プロセッサに接続された表示装置と、

30 上記プロセッサに接続されたコントローラと、 各々がM個のセクタからなるN個のクラスタを有し (M、Nは各々2以上の整数)、クラスタ単位で消去す ることが可能な一括消去型不揮発性メモリとを備え、 上記N個のクラスタの各々にクラスタ情報セクタが確保

上記コントローラの動作に先立って、上記N個のクラス タに対して重複がないように順序番号が与えられ、各ク ラスタのクラスタ情報セクタに当該クラスタに割り当て られた順序番号が書き込まれており、且つ、上記N個の 40 クラスタ情報セクタの各々にはさらに当該クラスタの消 去回数が書き込まれ、上記N個のクラスタに与えられた 順序番号の最大値はそれらクラスタの消去回数の総和に

等しく設定されており、 上記コントローラは、

45 上記プロセッサのコマンドに含まれる論理アドレスを特 定のセクタを指示する物理アドレスに変換するために上 記ランダム・アクセス・メモリ上にアドレス変換表を作 成し、

所与のクラスタを消去するときは、先に当該所与のクラ 50 スタの順序番号と消去回数を保管し、

所与の消去済みクラスタを初期設定するときは、現在の 最大順序番号に1を加算し、且つ消去前に保管された消 去回数に1を加算し、それぞれの加算結果を当該所与の クラスタ順序番号及び消去回数としてそのクラスタ情報 セクタに書き込み、

上記アドレス変換表作成時に最大順序番号と上記N個の クラスタのクラスタ情報セクタに記憶された消去回数の 総和を比較し、不一致を検出したときには、上記表示装 置にエラー・メッセージを表示させるように、上記プロ セッサに対して要求することを特徴とするデータ処理シ

【請求項14】各々がM個のセクタからなるN個のクラ スタを有し (M、Nは各々2以上の整数)、クラスタ単 位で消去することが可能な、一括消去型不揮発性メモリ を用いた半導体ディスク装置の管理方法であって、

上記N個のクラスタに対して重複がないように順序番号 を与え、各クラスタにその割り当てられた順序番号を書 き込み、

所与のクラスタを消去するときは、当該クラスタの順序 番号を保管した後、当該クラスタを消去し、

所与の消去済みクラスタを初期設定するときは、現在の 最大順序番号よりも大きな値を当該クラスタの順序番号 としてそのクラスタに書き込むことを特徴とする半導体 ディスク装置の管理方法。

【請求項15】各々がM個のセクタからなるN個のクラ スタを有し (M、Nは各々2以上の整数)、クラスタ単 位で消去することが可能な、一括消去型不揮発性メモリ を用いた半導体ディスク装置の管理方法であって、

上記N個のクラスタに対して重複がないように順序番号 を与え、クラスタの夫々にその割り当てられた順序番号 と消去回数とを書き込み、上記N個のクラスタに与えら れた順序番号の最大値はそれらクラスタの消去回数の総 和に等しく設定し、

所与のクラスタを消去するときは、先に当該クラスタの 順序番号と消去回数を保管し、

所与の消去済みクラスタを初期設定するときは、現在の 最大順序番号に1を加算し、且つ消去前に保管された消 去回数に1を加算し、加算結果をそれぞれ当該所与のク ラスタの順序番号及び消去回数としてそのクラスタに書 き込むことを特徴とする半導体ディスク装置の管理方 法。

## 【発明の詳細な説明】

#### [0001]

【産業上の利用分野】本発明は、フラッシュEEPRO 型不揮発性メモリ及びそれを用いる半導体ディスク装置 に係り、特に、動的セクタ割当ての可能な半導体ディス ク装置に係る。

#### [0002]

・コンピュータの普及に伴って、コンピュータ・システ ムの小型軽量化、低消費電力化に対する要求が強くなっ てきている。半導体メモリを用いた外部記憶システム、 いわゆる半導体ディスク装置は、磁気ディスク装置のよ うに駆動系を持たないため、消費電力が低く、高速動作 が可能である。また、小さなメモリ・モジュールで構成 されるため、磁気ディスク装置に比べて小型で軽く、形 状に自由度が大きく、カード化も容易である。

【0003】しかし、従来の半導体メモリにはコスト、 容量、電池バックアップなどの点でまだ問題が多い。メ モリとしてSRAMを使うと電池によるバックアップの 時間は長くなるが、コストが高く、容量も小さくなって しまう。コスト、容量に優れたDRAMでは、スタンバ イ時の消費電力が大きく、バックアップの時間が一週間 程度に限られてしまう。電池系の事故によるデータ消失 . 15 の危険もある。EEPROMは電池を必要としないが、 コストが高すぎる。

【0004】これらの問題を解決するメモリとして一括 消去型のフラッシュ・メモリが開発されている。DRA 20 Mと同じくトランジスタ1つで記憶素子が構成され、高 密度化が可能で、将来の市場次第でDRAMと同等かそ れ以下のビット単価(低コスト、大容量)になることが 期待されている。記憶素子は不揮発性であり、電池バッ クアップの必要はない。消去は一般にチップ単位又はそ 25 れよりも小さなブロック単位で行われる。Richard D. P ashley 外の "Flash memories: the best of two world s"、IEEE SPECTRUM 1989年12月、30~33頁は、このよ うなフラッシュ・メモリの概要を紹介している。パフォ ーマンスの点では、チップ消去型よりプロック消去型の 方が優れている。

【0005】プロック消去型のフラッシュ・メモリを半 導体ディスク装置に用いる場合は、ブロックの大きさを ハード・ディスク装置のアクセス単位であるセクタに等 しくしておくと、メモリ管理に都合がよい。例えば、ヨ 35 ーロッパ公開特許出願第392895号はセクタ消去型 のフラッシュEEPROMシステムを開示している。こ のシステムは、消去単位であるセクタ毎にラッチを設け ておき、消去したいセクタに対応するラッチをセットす ることによって、任意の複数のセクタを同時に消去でき 40 るようにしている。複数セクタ分の容量(例えば4Kバ イト)を持ったプロックを消去単位にしたフラッシュ・ メモリも知られている。

【0006】しかし、フラッシュ・メモリにはSRAM やDRAMにはない制限がある。まず、メモリ・ビット M (以下ではフラッシュ・メモリと呼ぶ) 等の一括消去 45 のプログラミングは一方通行で、0から1又は1から0 へしか変えることができない。従って、既に書込まれて いる記憶位置に新たなデータを書込む場合は、その記憶 位置を含むプロックを一括消去によって全0又は全1に 設定した後に書込みを行う必要がある。消去及び書込み

【従来の技術】ノートプック等の携帯可能なパーソナル 50 には、通常、数十ミリ秒から数秒の時間がかかる。ま

05

た、フラッシュ・メモリは消去及び曹込みによって劣化 し、現在のところ、数万回から数十万回の消去及び書込 みで使用限度に達してしまう。

【0007】このようなフラッシュ・メモリを半導体デ ィスク装置に用いた場合、同一の論理セクタを同一の物 理セクタに割り当てていたのでは、書込みがメモリの一 部に片寄ることが問題になる。例えば、DOSベースの パーソナル・コンピュータ・システムでは、ファイル・ アロケーション・テーブル (FAT) の書換えがしばし ば行われる。ところが、FATのアドレスは固定されて いるため、フラッシュ・メモリを用いた場合には、FA Tの曹換えの度にそれを記憶しているブロックの消去及 び魯込みを行う必要があり、その度に数十ミリ秒から数 秒の時間がかかってしまう。また、このように書込み及 び消去がメモリの一部のブロックに片寄ると、そのブロ 15 必要がある。そのときには、SSFの各セクタを読み、 ックが他のプロックに比べて早く使用限度に達してしま い、他のブロックがまだ使用可能であるにもかかわら ず、メモリを交換しなければならなくなる。使用限度に 達したブロックを無効化して、代替ブロックを使用する ようにすれば、メモリの早期交換は避けられるが、書込 20 みが集中するのが代替ブロックに変わっただけであり、 根本的な解決にはなっていない。

【0008】そこで、特願平3-197318号では、 動的セクタ割当て法を用いることにより、この問題の解 決に成功している。図1と図2を参照して、その概要を 説明する。RAMにアドレス変換表が作成され、これを 参照することにより、ホスト・プロセッサの指定するア ドレス (論理アドレス) が半導体ディスク装置 (SS F) のセクタ (物理セクタ) を指定するアドレス (物理 アドレス) に変換される。即ち、ホスト・プロセッサ は、ヘッド番号、シリンダ番号、セクタ番号からなる論 理アドレスでもってデータ書込み場所を指定する。アド レス変換表の論理アドレスで特定される項目には、当該 論理アドレスに対応する物理アドレスが記憶される。物 理アドレスによって指定されることになるSSFの各セ 35 使えない。 クタには、データを記憶するデータ領域の他に、逆参照 ポインタ (RP) を記憶する領域とそのセクタの状況を 記憶する領域が含まれる。

【0009】今、SSFがホスト・プロセッサから論理 みコマンドを受け取ったときに、それまで空であった物 理アドレスABCのセクタYをこの論理アドレスに割り 当てたとする。SSFのコントローラは、物理セクタY のデータ領域にデータを書き込むとともに、RP領域 (1.4.5) を書き込み、状況領域に有効であること を示すフラグを立てる。同時に、論理アドレス(1, 4, 5) によって特定される変換表の項目Xに物理アド レスABCを書き込む。以後、論理アドレス(1, 4, 5)からのデータの読出しが要求されたときは、アドレ

る (図1参照)。

【0010】再びSSFがホスト・プロセッサから論理 アドレス (H, C, S) = (1, 4, 5) に対する書込 みコマンドを受け取ったとき、SSFのコントローラ 05 は、物理セクタYを無効にし、それまで空であった物理 セクタを論理アドレス(1,4,5)に割り当てる。例 えば、アドレス変換表の項目XをABDに書き換え、S SFの物理アドレスABDのセクタZのデータ領域にデ ータを書き込み、RP領域に(1, 4, 5)を書き込 10 み、状況領域に有効であることを示すフラグを立てる。 同時に、セクタYの状況領域に無効であることを示すフ ラグを立てる。

【0011】さて、パワーオフするとアドレス変換表は 失われてしまうから、パワーオン時にこれを再構成する 逆参照ポインタで指定されるアドレス変換表の項目に、 当該セクタの物理アドレスを登録する。図2に示すよう に、同じRPを持つセクタが複数あるときは、有効であ るセクタの物理アドレスを登録する。このように、SS Fのセクタの有効・無効の情報は、動的割当ての要であ るアドレス変換表の再構成に不可欠である。

【0012】ところで、先に述べた通り、フラッシュ・ メモリに於いてはブロックの消去後でなければそこに含 まれるセクタにデータを書き込むことができないので、 25 一般的にはセクタの状況を更新することは困難である。 この問題に対して、特願平3-197318号では、一 部のフラッシュ・メモリが有する、ビット変化が一方向 に限定されている場合は重ね書きができるという特質に 基づき、状況フラグビットを "1111" -> "1110" -> " 30 1100"-> "0000" のように変化させることで、各セクタ の「空白」、「有効」、「無効」及び「消去中」を示す 方法を開示している。しかしながら、NAND型のセル 構造を持つフラッシュ・メモリの中には、全く重ね書き できないものがあり、状況フラグビットを用いた方法は

#### [0013]

【発明が解決しようとする課題】本発明の目的は、重ね 書きの手法を用いなくても無効セクタと有効セクタとを 見分けることが可能な一括消去型不揮発性メモリ及びそ アドレス (H, C, S) = (1, 4, 5) に対する書込 40 れを用いた半導体ディスク装置を提供することを目的と する。

#### [0014]

【課題を解決するための手段】本発明に従う一括消去型 不揮発性メモリは、各々がM個のセクタからなるN個の 45 クラスタを有し (M、Nは各々2以上の整数)、クラス タ単位で消去することが可能であり、上記N個のクラス タの各々にクラスタ情報セクタが確保され、予め上記N 個のクラスタに対して重複がないように順序番号が与え られ、各クラスタのクラスタ情報セクタに当該クラスタ ス変換表を使って、物理アドレスABCがアクセスされ 50 に割り当てられた順序番号が書き込まれている。本発明 に従う半導体ディスク装置は、そのような一括消去型不 揮発性メモリとそれに接続されたコントローラを含む。 動的セクタ割当てを実行するため、コントローラは、ラ ンダム・アクセス・メモリ上にアドレス変換表の領域を 確保し、プロセッサが所与の論理アドレスを指定して書 05 込みを要求したときに、空白セクタを一つ選択し、アド レス換表の当該所与の論理アドレスによって指示される 項目に当該選択されたセクタの物理アドレスを 書き込 み、且つ当該選択されたセクタに当該所与の論理アドレ スを逆参照ポインタとして書き込む。

【0015】コントローラはまた、所与のクラスタを消 去するとき、先に当該クラスタの順序番号を他のクラス タ等の不揮発性の記憶領域に保管する。そして、所与の 消去済みクラスタを初期設定するときには、現在の最大 順序番号よりも大きな値を当該クラスタの順序番号とし てそのクラスタ情報セクタに書き込む。

【0016】このようにして初期設定されたクラスタの クラスタ情報セクタ以外のセクタに対して、コントロー ラは、それらセクタの物理アドレスの順番に従ってユー ザ・データを書き込む。

【0017】パワーオン時にアドレス変換表を再構成す るとき、コントローラは、不揮発性メモリのM×N個の セクタを読み出し、読み出されたセクタの逆参照ポイン タによって指示されるアドレス変換表の項目に当該セク タの物理アドレスを書き込む。同じ逆参照ポインタを持 つセクタが複数あるときには、それらセクタの属するク ラスタの順序番号とクラスタ内での位置に従って、最も 新しく書き込まれたセクタの物理アドレスをアドレス変 換表に書き込む。

【0018】予め各クラスタ情報セクタにそれを含むク ラスタの消去回数を書き込み、最大順序番号は全クラス タの消去回数の総和に等しくなるように設定しておいた 場合には、クラスタ消去時に順序番号とともに消去回数 も保管する。そして、消去済みのクラスタを初期設定す るときに、保管されていた当該クラスタの消去回数を順 35 れたコントローラ30と、内部バス31を介してこのコ 序番号と同様にカウントアップしてそのクラスタ情報セ クタに書き戻す。アドレス変換表再構成時において、全 クラスタ情報セクタが読み出されることを利用して、最 大順序番号と全クラスタの消去回数の総和が一致するか をチェックする。これによって、データの信頼性が維持 されているか否かが判る。

### [0019]

【実施例】本発明の半導体ディスク装置として組み込ん だコンピュータ・システムの一例を図3に示す。СР U 10はシステム・バス13を介して、主記憶装置15、 バス制御装置16及びオプションの数値計算用コプロセ ッサ14と通信する。CPU10及び関連する周辺装置 の間の通信はバス制御装置16を介して行われる。その ため、バス制御装置16はファミリー・バス18によっ て周辺装置に接続されている。周辺装置としては、本発

明に従うフラッシュ・メモリ製の半導体ディスク装置 (SSF) 20が接続され、さらに、通信装置21、フ ロッピー・ディスク・ドライブ (FDD) 22、光ファ イル装置23、表示装置24もファミリー・バス18に 接続されている。勿論、他の周辺装置も接続可能であ る。このようなコンピュータ・システムの一例はIBM PS/2である。

【0020】直接メモリ・アクセス制御装置(DMA) C) 12は、これらの周辺装置の全部又は選択された何 10 台かによるメモリ・アクセスを可能にすべく設けられ る。そのため、ファミリー・バス18は、少なくともそ の一部がDMAC12に分岐接続される。図には示して いないが、DMAが可能な各周辺装置にはアービトレー ション回路が設けられ、アービトレーション・レベル (優先順位)を割り当てられる。DMAC12の側に は、DMAを同時に要求している複数の周辺装置の間で 調停作業を行って、どの周辺装置がDMAを許可された かをDMAC12に知らせる中央アービトレーション制 御回路11が設けられる。DMAC12及び中央アービ トレーション制御回路11によるDMA制御の詳細は米 20 国特許第4901234号明細書に記載されている。

【0021】CPU10はSSF20をハード・ディス ク装置として扱う。従って、SSF20をアクセスする ときは、ヘッド番号、シリンダ番号及びセクタ番号から 成るいわゆる相対ブロック・アドレス(RBA)がSS F20に送られる。SSF20は動的セクタ割当てを行 う。従って、CPU10から供給されるRBAと、SS F20の実際にアクセスされるセクタのアドレス(物理 アドレス)との間の関係は固定されておらず、書込みの 30 度に変化する。そこで、それらの対応関係を明らかにす るアドレス変換表が設けられる。即ち、CPU10から のRBAは論理アドレスである。

【0022】図4に、SSF20の概略的な構成を示 す。このSSF20は、ファミリー・バス18に接続さ ントローラ30に接続されたランダム・アクセス・メモ リ(RAM)32、バス制御部33及びフラッシュ・メ モリ34で構成される。RAM32は、アドレス変換表 を記憶する領域35及びバッファ領域36を含む。RA 40 M32はこの他に後述する最大順序番号 (M) を記憶す る領域も含む。バス制御部33は、内部バス31と、フ ラッシュ・メモリ34に接続されたメモリ・バス37と を相互接続するための周知のレシーバ/ドライバ構成を 有する。

【0023】本実施例では、CPUの指定する論理セク タのサイズは512バイトであり、CPU10のSSF 20に対する最小アクセス単位である物理セクタのサイ ズは512バイト+αである(図5、図6参照)。16 Mビットのフラッシュ・メモリ・チップを用いる場合、 50 1物理セクタはワード・ライン2本を占める。つまり、

2ページで1セクタを構成する。SSF20のセクタ (物理セクタ) は次のようにして管理される。

【0024】1) 実際の消去を行う論理的な集合をつく り、これをクラスタと呼ぶ。クラスタは物理的な消去単 位であるプロックの1つ以上からなる。実施例では8セ クタで1プロックを構成し、8プロックで1クラスタを 構成する。各クラスタにクラスタ情報セクタを作成し、 クラスタ消去回数及び順序番号の領域を確保する。クラ スタ消去回数及び順序番号はクラスタ情報セクタ中の管 タの先頭の物理アドレスに位置するセクタをクラスタ情 . 報セクタに割り当てる。

以外のセクタ(以下ではデータ・セクタと呼ぶ)の構成 を示す。図示のように、データ・セクタは、512バイ トのユーザ・データを記憶するデータ領域の他に、属性 及びエラー訂正符号 (ECC) を記憶する領域を含む。 【0026】ここでは、特願平3-197318号とは 違って、セクタに有効・無効のフラグを立てる状況領域 がないことに注目されたい。なお、各セクタに共通に含 まれる属性は、そのセクタがクラスタ情報セクタである か否かを識別するのに用いられる。

【0025】図6は、各クラスタのクラスタ情報セクタ

【0027】2) SSF製造後のフラッシュ・メモリ・ チップ全体の初期設定工程において、クラスタ別に初期 順序番号を重複しないように与える。このとき、全クラ スタの消去回数の総和が最大順序番号に等しいという条 件を付すのが望ましい。

【0028】図7に示すように、SSD中にN個のクラ スタが有り、各クラスタに1からNまでのクラスタ番号 を与えたとする。 (実際には、クラスタ番号はアドレス 30 ・バスの上位複数ビットで指定される。)工場のコンピ ュータによって実行されるSSD初期設定プログラム は、各クラスタのクラスタ消去回数を"1"に設定す る。同時にクラスタ番号iのクラスタの順序番号とし て"i"を書き込み、順序番号が重複しないようにす

【0029】この例ではクラスタ消去回数の初期値とし て1を与えているが、本発明は実際の消去回数を書き込 んだ場合でも実施可能である。また、この例では順序番 号の初期値の順をクラスタ番号の順に一致させている が、本発明はそのような初期順序番号の与え方に限定さ れるものではなく、クラスタ番号に無関係に初期順序番 号を割り当ててよい。

【0030】セクタの有効・無効を判別するために必要 とされる条件は、順序番号の重複がないようにすること である。実施例ではさらに順序番号の最大値(最大順序 番号)が各クラスタの消去回数の総和に等しいように設 定されている。以上の二つの条件は、クラスタ消去時を 除き、SSDが稼働しているどの時点においても満たさ

回数の総和はNであり、順序番号の最大値もNであるの で、条件を満たしている。

【0031】もし、図7の例で、クラスタNのクラスタ 消去回数が2であり、その他のクラスタのクラスタ消去 回数が1であるならば、クラスタ1からクラスタN-1 に順序番号1からN-1を割り当て、クラスタNに順序 番号N+1を割り当てれば、上記二つの条件を満たすこ とになる。

【0032】3)図8を参照して、クラスタ消去時のコ 理情報の一部として保管される。実施例では、各クラス 10 ントローラ30 (図4) の動作を説明する。まず、消去 するクラスタを決定する。様々な決定方法があるが、有。 効セクタの数が一定値を下回ったときに、そのクラスタ を消去対象として決定するのが一般的である(ステップ 80)。次に、消去するクラスタをXとすると、コント 15 ローラは、Xの有効データを他のクラスタのデータ・セ クタに複写する(ステップ81)。

> 【0033】ステップ80、81を実行するためには、 セクタの有効・無効の判別ができなければならないが、 それは所与のセクタの逆参照ポインタが指示するアドレ ス変換表の項目を参照し、その項目に書き込まれている アドレスが当該セクタのアドレスと一致するかを調べれ ばよい。一致すればそのセクタは有効であり、一致しな ければ無効である。ステップ81ではそのようにして有 効セクタを検出する。また、一度クラスタごとに有効・ 25 無効セクタの数を調べて結果をRAM32 (図4) に設 けた表(図示せず)に記録し、以後書き込みが行われる 度にその表を更新するようにすれば、その表を定期的に 参照することによって、消去すべきクラスタを判別する ことができる。

> 【0034】次に、コントローラは、クラスタXのクラ スタ情報セクタを他の適当なクラスタのデータ・セクタ や電池バックアップされたRAM等の不揮発性記憶領域 に複写して、クラスタXの現在の順序番号と消去回数を 保管する(ステップ82)。その後、クラスタXを消去 35 する (ステップ83)。消去済みクラスタを初期設定す る必要があるとき、即ち、データ・セクタが完全に空白 であるクラスタがないときには、直ちに初期設定処理が 行われるが (ステップ85) 、そうでなければ、SSD は通常のオペレーションを行う(ステップ86)。ここ 40 でいう初期設定とは、消去済みのクラスタのクラスタ情 報セクタに順序番号等を書き込み、データ・セクタに対 して書き込み可能な状態にすることである。

> 【0035】図9を参照して、消去済みクラスタ初期設 定時のコントローラ30(図4)の動作を説明する。ま 45 ず、コントローラは、消去済みではあるがまだ初期設定 されていない1以上のクラスタの中からクラスタ消去回 数が最小のものを選択する(ステップ90)。選択され たクラスタをCとする。

【0036】次に、現在の最大順序番号Mを求め、これ れなければならない。図7に示した例ではクラスタ消去 50 に1を加えた値M+1をクラスタCの順序番号としてそ

のクラスタ情報セクタに書き込む(ステップ91)。こ こで、最大順序番号MはRAM32の領域38に記憶さ れているので、それをアクセスする。ステップ92で は、領域38に値M+1が書き込まれる。

【0037】しかる後、ステップ93において、クラス タCを消去するときにステップ82で保管した消去回数 を読み出し、それに1を加えた値をクラスタCのクラス タ情報セクタに書き込む。順序番号、クラスタ消去回 数、ECC以外のクラスタ管理情報は、クラスタCを消 去するときに保管した管理情報をそのまま書き込む。

> クラスタ消去回数 順序番号

最大順序番号

【0040】上の例では、現在の最大順序番号Mに1を 加えた値をクラスタ情報セクタに書き込んだが、要は現 在の最大順序番号Mよりも大きな値を書き込めばよいの であって、増分を1に限る必要はない。

【0041】4)セクタへの書き込みは、動的セクタ割 当て法を用いる。ただし、特願平3-197318号と 20 は違って、有効・無効のフラグを立てる操作は行わな い。同一のクラスタの中では、セクタはそのアドレスの 昇順または降順に書き込まれていく。実施例ではクラス タ情報セクタをクラスタの先頭に置いたので、アドレス の昇順にセクタへデータを書き込むが、クラスタの末尾 25 に置いた場合はアドレスの降順にセクタへデータを書き 込むことになる。

【0042】一つのクラスタに対する書き込みが終わる まで、即ちクラスタがデータで満たされるか、あるいは 途中で書き込みを打ち切り、以降のセクタに書き込みを 行わないと判断されるまで、他のクラスタにはデータを **書き込まない。クラスタの途中から後のセクタが全て不** 良であるとき、データの書き込みは途中で打ち切られ る。不良セクタの情報はSSF製造後の初期設定工程で 予めフラッシュ・メモリ34の一部に書き込まれている ので、そのような打ち切りの判断は可能である。

【0043】当初は2)で割り当てられた初期順序番号 にしたがってクラスタへのユーザ・データの書き込みを 行うが、一通り全クラスタにデータを書き込んだ後は、 消去と初期設定の過程を経て最大順序番号が付与された 40 クラスタに対して書き込みを行う。

【0044】一般的に全てのセクタの時間的前後関係を 得ることができれば有効セクタと無効セクタとを見分け ることはたやすい。しかしながら、全てのセクタに対し て時間情報を書き込むことは、時間情報領域のオーバー ヘッドが大きすぎて事実上不可能である。本発明ではこ の時間情報を二段階の階層構造によって保持する。第一 の階層はクラスタであり、第二の階層はクラスタに含ま れるセクタである。3)で述べた消去方法によれば、ク ラスタ情報セクタに書かれた順序番号によってクラスタ 50 って指示されるアドレス変換表の項目に、当該セクタの

【0038】図8および図9に示した制御の流れは一例 にすぎず、これを様々に変形することが可能である。例 えば、消去したクラスタを直ちに初期設定しても差し支 えなく、その場合には、図8のステップ83の次に直ち に図9のステップ91に飛ぶことになる。その結果、消 去されたクラスタのクラスタ消去回数及び順序番号、及 びRAMに保存される最大順序番号は以下のように変化 する。

[0039]

10

| 消去前の値 | 初期設定後の値 |
|-------|---------|
| E     | E + 1   |
| S     | M+1     |
| M     | M+1     |

間の時間的前後関係を決定することができ、4)で述べ た書き込み方法により第二の階層であるクラスタ内セク タの時間情報がセクタの位置として保存される。これら を組み合わせることにより、全セクタの時間的前後関係 を一意に決定することが可能であり、かつ、時間情報を 書き込む領域のオーバーヘッドは非常に少ない。

【0045】5)パワーオン時には、クラスタ情報セク タ内の順序番号とクラスタ内でのセクタの位置を手がか りにして、セクタの有効・無効を判別しつつ、アドレス 変換表を再構成する。特定の論理セクタに対応する複数 の物理セクタが存在する場合、最大の順序番号を持つク ラスタにあるものを有効とする。同一のクラスタに、同 一論理セクタに対応する複数の物理セクタが存在する場 合は、その位置による時系列情報により有効セクタを決 定する。

【0046】以上を実現する方法としては二つの方法が 考えられる。第一の方法は順序番号をまずソートしてそ の順にクラスタを走査する方法であり、第二の方法はR AMに順序番号表を作るものである。前者はソートが完 了してしまえば以後の処理は高速であり利点も多い。し 35 かしながら、ソートに先立ち順序番号を全て読み込まな ければならず、従ってクラスタの管理情報を二回読む事 になる。さらに、高速なソートを行うには一般的に大き な作業領域を必要とするため状況によってはSSFのコ スト上昇を招く場合がある。

【0047】図10を参照して、第一の方法の処理の流 れを説明する。まず、アドレス変換表の領域をRAMに 確保し、各項目の値を特別な値(例えばゼロ)に初期設 定する(ステップ100)。次に、すべてのクラスタ情 報セクタを読み出し、順序番号を昇順にソートする(ス 45 テップ101、102)。しかる後、順序番号の小さな ものから順にクラスタを選び、選んだクラスタのセクタ をアドレスの順に読む出す。実施例では、クラスタ情報 セクタから始まってアドレスの昇順にセクタを順次読む ことになる。読み出されたセクタの逆参照ポインタによ

物理アドレスを書き込む。その項目に既に他のセクタのアドレスが書き込まれてあっても、現在読まれたセクタのアドレスを書き込む。 (ステップ103~108)。

【0048】図11を参照して、第二の方法で用いる順 序番号表について説明する。この方法では、第Nクラス タの順序番号を第N項目に格納するような順序番号表を RAM32 (図4) に作成する。1クラスタ当たり64 セクタである様な40MビットのSSFを考えると、ク ラスタ数は冗長分を除けば1280であり、順序番号表 の1エントリーを5バイトとすれば順序番号表の領域は 約6Kバイトとなる。また、動的セクタ割当て法使用時 にはアドレス変換表がRAM上に存在するが、この表の 各項目の値のうち、下位6ビットを除いた上位18ビッ トがクラスタ番号に相当する(以下、上位18ビットを クラスタポインタと呼ぶ)。今、第Sセクタのクラスタ ポインタの内容がPであったとすると、順序番号表の第 P項目を読むことにより、第Sセクタの存在するクラス タの順序番号を得ることが出来る。図11の例だと、ア ドレス変換表は論理セクタSの実体がクラスタPのQ番 目に存在することを示し、順序番号表はクラスタPの順 序番号が1234であることを示している。なお、図1 1において、Nsは論理セクタの総数であり、Ncはク ラスタの総数である。

【0049】次に、図12を参照して、第二の方法の処理の流れを説明する。 $\alpha$ ]まず、アドレス変換表の領域をRAMに確保し、各項目の値を特別な値(例えばゼロ)に初期設定する(ステップ120)。次に、クラスタを選び、そのクラスタの順序番号を順序番号表に登録する。実施例ではクラスタ番号の昇順にクラスタを選択しているが、クラスタを選択する順番は任意とすることができる(ステップ121、122、123、134)。選ばれたクラスタをCとすると、クラスタC内では時系列順にセクタを走査し、各セクタのRP領域の逆参照ポインタを読み出す(ステップ124、125、133)。

【0050】 $\beta$ ]特願平3-197318号特許出願の方法により、逆参照ポインタからアドレス変換表を再構成する。この時、逆参照ポインタによって指示されるアドレス変換表の項目に既に他のセクタの物理アドレスが書き込まれているか否かで動作が異なる(ステップ126、127)。

【0051】◎ 当該項目が空白である場合 当該項目に、ステップ125で読み出されたセクタSの 物理アドレスを書き込む(ステップ130)。

【0052】◎ 当該項目が空白でない場合 当該項目のクラスタポインタにより順序番号表を検索 し、当該項目に既に登録されているセクタSが属するク ラスタの順序番号を求める(ステップ128)。これを 現在読み出し中のクラスタCの順序番号と大小比較する (ステップ129)。前者の方が小さければ当該項目に セクタSのアドレスを書き込む (ステップ130)。そ うでないときは何もせず既に登録されているセクタを有 05 効のままにする。

【0053】 $\gamma$ 】以上を全てのクラスタ及びセクタについて繰り返すことによりアドレス変換表には有効セクタのみが登録される(ステップ131、132)。

【0054】アドレス変換表を再構成した後、コントロ10 ーラ30(図4)は最大順序番号をRAM32の作業域に保存し、順序番号表の領域を解放する。既に述べたように、最大順序番号は消去済みクラスタの初期設定で必要とされる。

【0055】コントローラ30はさらに、アドレス変換表再構成時に全クラスタのクラスタ情報セクタを読み出すことを利用して、全クラスタの順序番号の総和と最大順序番号とを比較する。ここで両者の値が不一致である場合は、データの信頼性が損なわれていることを意味するので、コントローラ30はCPU10(図3)に対して、表示装置24にエラー・メッセージを表示させることを要求する。

[0056]

【発明の効果】本発明に従えば、一括消去型不揮発性メモリを用いた半導体ディスク装置において重ね書きの手 25 法を用いなくても無効セクタと有効セクタとを見分けることが可能になる。

【図面の簡単な説明】

【図1】特願平3-197318号で開示された動的セクタ割当ての説明図。

30 【図2】特願平3-197318号で開示された動的セクタ割当ての説明図。

【図3】本発明に従う半導体ディスク装置を組み込んだ コンピュータ・システムの一例を示すブロック図。

【図4】半導体ディスク装置の概略構成を示す図。

35 【図5】クラスタ情報セクタの構成を示す図。

【図6】クラスタ情報セクタ以外のセクタ (データ・セクタ) の構成を示す図。

【図7】クラスタ情報セクタの初期値の設定を示す図。

【図8】クラスタ消去時のコントローラの動作を示すフ 40 ローチャート。

【図9】消去済みクラスタを初期設定するときのコントローラの動作を示すフローチャート。

【図10】アドレス変換表再構成時のコントローラの動作の一例を示すフローチャート。

45 【図11】アドレス変換表と順序番号表の関係を示す 図。

【図12】アドレス変換表再構成時のコントローラの動作の一例を示すフローチャート。





[図2]



【図4】



【図6】

| ユーザ・データ | 属性フラグ | ECC |
|---------|-------|-----|
| _ , , , |       |     |



【図5】







【図11】





フロントページの続き

(72) 発明者 浅野 秀夫

東京都千代田区三番町 5-19 日本アイD ビー・エム株式会社 東京基礎研究所内 (72) 発明者 坂上 好功

東京都千代田区三番町 5 - 19 日本アイD ビー・エム株式会社 東京基礎研究所内 (72)発明者 豊岡 孝資

東京都千代田区三番町 5 - 19 日本アイD ビー・エム株式会社 東京基礎研究所内